What Is Claimed Is: 

\l . A method of testing a program, said method comprising: 

dividing said program into a plurality of groups, wherein each of said plurality of groups 
contains a sequence of statements such that a tester can be sure that all the sequence of statements 
of a group are exearted if at least one statement of said group is executed; 

determining a plurality of executed groups when said program is executed while testing 
said program; 

indicating a plurality of unexecuted groups, wherein said plurality of unexecuted groups 
are determined based on said determining; and 

enabling said tester to execute said plurality of unexecuted groups such that said tester can 
ensure that all statements in said program ar\executed at least once. 



2. The method of claim 1, further comprising^mcluding an extra statement in each of said 
groups, wherein execution of said extra statement enables said determining to identify the 
execution of said extra statement in the corresponding group. 



3. The method of claim 2, wherein said extra statement contains a group identifier, 
wherein said determining further comprises examining said group identifier to determine the 
specific group which has been executed. 

4. The method of claim 2, wherein said program is contained in a plurality of programs 
which in turn are contained in a class of an object oriented environment. 
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\5. The method of claim 4, further comprising grouping a plurality of sequential groups 
into a blofclc, and wherein said indicating comprises indicating that said block has been executed 
only if all groups of the block are executed. 

6. The method of claim 5, wherein said grouping comprises: 
determining a langiWe structure present in said plurality of programs; 

grouping a subset of groups present in said language structure into a block such that the 
statements in said language structure^re presented as a block to said tester. 

7. The method of claim 6, wherein said blocks are defined hierarchically according to the 
inclusive relationship of language structures in saidvplurality of programs. 

8. The method of claim 7, wherein said language structure comprises one of program 
delimiters, control structure and loop structure. \ 

9. The method of claim 4, wherein said enabling comprises: \ 

enabling said tester to examine the statements associated with saicrunexecuted blocks such 
that said tester can determine the arguments which would cause an unexecuted block to be 
executed; \ 

enabling said tester to enter said determined arguments to cause said unexecuted block to 
be executed. \ 
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\ 10. The method of claim 9, wherein said argument comprises an instance of another 
object) 

11. The method of claim 10, further comprises: 
enabling said tester to instantiate said instance of said another object; 
enabling saidytester to assign a name to said instance, wherein said tester can enter said 

name to provide said instance as an argument value. 

12. The method of claftn 11, further comprising: 
receiving a string as an argument; and 

determining that said string indicates that said instance is said argument value if said name 
matches said string. 

13. The method of claim 4, further comprising: 

enabling said tester to define a macro containing a plurality of program lines; 
storing said macro in a database; and 

enabling said tester to execute said macro in the middl^of testing said plurality of 
programs. 



14. The method of claim 13, wherein said macro is designed to extaiine the data 
structures within an instance of an object or to set the values for the variables in the object. 
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\ 15. The method of claim 4, wherein said dividing, determining, indicating and enabling are 
performed in a single computer system. 

16. The^method of claim 4, wherein said object is generated in Java Programming 
language. \ 

17. The method of claim 4, further comprising: 
enabling said tester to load said class; 

enabling said tester to instantiate an instance of said class; and 
enabling said tester to execute skid program on said instance. 



18. A computer program product for ifee with a computer system, said computer program 
product comprising a computer usable medium havhrn computer readable program code means 
embodied in said computer usable medium, said computer readable program code means enabling 
testing of a program, said computer readable program codeWans comprising: 

dividing means for dividing said program into a plurahtjrof groups, wherein each of said 
plurality of groups contains a sequence of statements such that a tester can be sure that all the 
sequence of statements of a group are executed if at least one statemenrsof said group is executed; 

determining means for determining a plurality of executed groups when said program is 
executed while testing said class; \ 

indicating means for indicating a plurality of unexecuted groups, wherein skid plurality of 
unexecuted groups are determined based on said determining; and \ 
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enabling means for enabling said tester to execute said plurality of unexecuted groups such 
that ^aid tester can ensure that all statements in said program are executed at least once. 

19. \The computer program product of claim 18, further comprising including means for 
including an extta statement in each of said groups, wherein execution of said extra statement 
enables said determining means to identify the execution of said extra statement in the 
corresponding group \ 

20. The computer programvproduct of claim 19, wherein said extra statement contains a 
group identifier, wherein said determimng means examines said group identifier to determine the 
specific group which has been executed. \ 

21. The computer program product of claim 19, wherein said program is contained in a 
plurality of programs which in turn are contained in a^class of an object oriented environment. 

22. The computer program product of claim 21, further comprising grouping means for 
grouping a plurality of sequential groups into a block, and wherein said indicating means indicates 
that said block has been executed only if all groups of the block are executed. 

23. The computer program product of claim 22, wherein said grouping means comprises: 
determining means for determining a language structure present in said plurality of 

programs; \ 
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a second grouping means for grouping a subset of groups present in said language 
stnirture into a block such that the statements in said language structure are presented as a block 
to said tester. 

24. Thescomputer program product of claim 23, wherein said blocks are defined 
hierarchically accora^ng to the inclusive relationship of language structures in said plurality of 
programs. 



25. The computer progtom product of claim 21, wherein said enabling means comprises: 
second enabling means for enabling said tester to examine the statements associated with 

said unexecuted blocks such that saidt^ster can determine the arguments which would cause an 

unexecuted block to be executed; 

third enabling means for enabling said tester to enter said determined arguments to cause 

said unexecuted block to be executed. 



26. The computer program product of claim 21, furtherscomprises: 
means for enabling said tester to instantiate said instance of said another object; 
means for enabling said tester to assign a name to said instance\/herein said tester can 
enter said name to provide said instance as an argument value. 



27. The computer program product of claim 26, further comprising: 
means for receiving a string as an argument; and 
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means for determining that said string indicates that said instance is said argument if said 
name matches said string. 

28. The^omputer program product of claim 28, wherein said macro is designed to 
examine the data strictures within an instance of an object or to set the values for the variables in 
the object. 

29. The computer program product of claim 21, further comprising: 
second enabling means for enabling said tester to define a macro containing a plurality of 

program lines; 

storing means for storing said macroYand 

third enabling means for enabling said tester to execute said macro in the middle of testing 
said plurality of programs. 



30. The computer program product of claim 26, further comprising: 
means for enabling said tester to load said class; 
means for enabling said tester to instantiate an instance of said class; and 
means for enabling said tester to execute said program on saichnstance. 



3 1 . A system enabling a tester to test a program, said computer systemsfomprising: 
a random access memory (RAM); 
a display unit containing a display screen; 
an input interface; 
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\ a processor dividing said program into a plurality of groups, wherein each of said plurality 
of groups contains a sequence of statements such that a tester can be sure that all the sequence of 
statements.of a group are executed if at least one statement of said group is executed, 

said processor executing said program in response to instructions received from said input 
interface, \ 

said processor determining a plurality of executed groups when said program is executed, 



indicating a plurality of unexecuted groups; and 

said processor enabling said tester to execute said plurality of unexecuted groups such that 
said tester can ensure that all statements^ said program are executed at least once. 

32. The system of claim 31, wherein saiXprocessor includes an extra statement in each of 
said groups, wherein execution of said extra statemeht enables said processor to identify the 
execution of said extra statement in the corresponding gfoup, said computer system further 
comprising a secondary storage wherein said processor store^said program including said extra 
statement on said secondary storage. \ 

33. The system of claim 32, wherein said extra statement contains a group identifier, 
wherein said processor examines said group identifier to determine the specufc group which has 
been executed. \ 

34. The system of claim 32, wherein said program is contained in a plurality of programs 
which in turn are contained in a class of an object oriented environment. \ 
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said processor causing a display to be generated on said display unit, said display 




\35. The system of claim 34, wherein said processor groups a plurality of sequential 
groups int^a block, and wherein said display indicates that said block has been executed only if 
all groups of thevblock are executed. 



36. The system ofclaim 35, wherein said processor groups said sequential groups 
according to a language structure present in said plurality of programs. 



37. The system of claim 36, wherein said blocks are defined hierarchically according to 
the inclusive relationship of language structures in said plurality of programs. 



38. The system of claim 34, wherein said processor receives instructions from said input 
interface to display the statements associated with saidunexecuted blocks, said processor causing 
the statements to be displayed on said display unit such that said tester can determine the 
arguments which would cause an unexecuted block to be^execute. 



39. The system of claim 38, wherein said argument comprises an instance of another 

object. 

40. The system of claim 39, wherein said processor instantiates saM instance of another 
object in response to receiving an instruction to instantiate said instance of said another object, 
said processor further associating a name associated with said instance of anotherobject, wherein 
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said&ame is received from said input interface and said tester can enter said name to provide said 
instancte as an argument value. 

41. The system of claim 40, wherein said processor receives a string as an argument and 
determines that said string indicates that said instance is said argument value if said name matches 
said string. \ 

42. The system of claun 34, wherein said processor receives a plurality of program lines 
representing a macro, said processor storing said macro in a database, said processor executing 
said macro in response to receiving ammstruction to execute said macro. 

43. The system of claim 42, wherein skid macro is designed to examine the data 
structures within an instance of an object or to sertfie values for the variables in the object. 

44. The system of claim 34, wherein said processor loads said class into said RAM in 
response to receiving an instruction to load said class, said processor further instantiating an 
instance of said class in response to receiving another instruction^ said processor executing said 
program on said instance in response to receiving one more instruction. 

45. The system of claim 3 1, wherein said input interface is connected to at least one of a 
mouse and a key-board. \ 
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